<!--
 * @Description  : 
 * @Version      : 1.0
 * @Author       : seraph
 * @Date         : 2025-02-18 17:00:08
 * @LastEditors  : seraph
 * @LastEditTime : 2025-02-20 18:29:55
-->
<template>
  <h3>展示过滤或排序后的结果​</h3>
  <p>有时，我们希望显示数组经过过滤或排序后的内容，而不实际变更或重置原始数据。在这种情况下，你可以创建返回已过滤或已排序数组的计算属性。</p>
  <p>举例来说：</p>
  <pre><code class="javascript" v-html="highlighted(rawCode1, 'javascript')"></code></pre>
  <pre><code class="html" v-html="highlighted(rawCode2, 'html')"></code></pre>
  <br>

  <p>在计算属性中使用 reverse() 和 sort() 的时候务必小心！这两个方法将变更原始数组，计算函数中不应该这么做。请在调用这些方法之前创建一个原数组的副本：</p>
  <pre><code class="javascript" v-html="highlighted(rawCode3, 'javascript')"></code></pre>
</template>



<script lang="ts" setup>
import { ref, nextTick, watch, Ref, onMounted, reactive } from 'vue'
import hljs from 'highlight.js';
import 'highlight.js/styles/atom-one-dark.css';
import javascript from 'highlight.js/lib/languages/javascript';
import html from 'highlight.js/lib/languages/xml';

hljs.registerLanguage('javascript', javascript);
hljs.registerLanguage('html', html);

const highlighted = (code: string, type: string) => {
  return hljs.highlight(code, { language: type }).value.replace(/&amp;lt;/g, '&lt;').replace(/&amp;gt;/g, '&gt;')
}

const getRenderingHTML = (items: { element: Ref<HTMLElement | null>; html: Ref<string> }[]) => {
  items.forEach((item) => {
    nextTick(() => {
      if (item.element.value) {
        item.html.value = item.element.value.outerHTML
      }
    })
  })
}

const rawCode1 = `const numbers = ref([1, 2, 3, 4, 5])

const evenNumbers = computed(() => {
  return numbers.value.filter((n) => n % 2 === 0)
})`

const rawCode2 = `<li v-for="n in evenNumbers">{{ n }}</li>`

const rawCode3 = `- return numbers.reverse()
+ return [...numbers].reverse()`





</script>


<style scoped>
p {
  font-size: 16px;
  padding: 2px;
  margin: 5px 0;
}

/* 设置预格式化文本的样式 */
pre {
  /* 背景色 */
  background-color: #f1ffed;
  /* 边框 */
  border: 1px solid #ccc;
  /* 缩小内边距 */
  padding: 5px 5px 5px 10px;
  /* 允许滚动 */
  overflow: auto;
  /* 可选：设置上下外边距 */
  margin: 0px 0;
  /* 允许换行 */
  /* normal: 连续的空白字符会被合并为一个空格。文本会在允许的断点处自动换行。
     nowrap：连续的空白字符会被合并为一个空格。文本不会自动换行，即使在允许的断点处也不会换行。
     pre：保留所有的空白字符（包括空格、制表符和换行符）。文本只会在遇到换行符或者 <br> 标签时换行。
     pre-wrap：保留所有的空白字符。文本会在遇到换行符、<br> 标签，或者达到容器边界时换行。
     pre-line：合并连续的空白字符为一个空格，但保留换行符。文本会在遇到换行符、<br> 标签，或者达到容器边界时换行。
   */
  white-space: pre-wrap;
  /* 行高 */
  line-height: 120%;
  /* 定义缩进 */
  tab-size: 4;
}

h3,
h4,
h5,
h6 {
  margin: 25px 0 10px 0;
  line-height: 100%;
}

.bolder {
  font-weight: bolder;
}

.red {
  color: red;
}

button {
  margin: 5px 5px 5px 10px;
  line-height: 150%;
  width: auto;
  padding: 0 10px;
}

.active {
  color: red;
}

.static {
  font-weight: bolder;
}

.text-danger {
  font-style: italic;
}
</style>
